From 62a78092095704338aada66e03743a7e4fadc22c Mon Sep 17 00:00:00 2001 From: Jimi Xenidis Date: Sun, 20 Aug 2006 13:28:45 -0400 Subject: [PATCH] [XEN][POWERPC] Xen shadow ops, mostly skeleton code Signed-off-by: Jimi Xenidis Signed-off-by: Hollis Blanchard --- xen/arch/powerpc/Makefile | 1 + xen/arch/powerpc/dom0_ops.c | 15 +++++++++++++++ xen/include/asm-powerpc/shadow.h | 4 ++++ 3 files changed, 20 insertions(+) diff --git a/xen/arch/powerpc/Makefile b/xen/arch/powerpc/Makefile index c16cd1977f..b17730832b 100644 --- a/xen/arch/powerpc/Makefile +++ b/xen/arch/powerpc/Makefile @@ -32,6 +32,7 @@ obj-y += ofd_fixup.o obj-y += physdev.o obj-y += rtas.o obj-y += setup.o +obj-y += shadow.o obj-y += smp.o obj-y += time.o obj-y += usercopy.o diff --git a/xen/arch/powerpc/dom0_ops.c b/xen/arch/powerpc/dom0_ops.c index ff4813d92c..9aa9118abf 100644 --- a/xen/arch/powerpc/dom0_ops.c +++ b/xen/arch/powerpc/dom0_ops.c @@ -23,6 +23,7 @@ #include #include #include +#include #include #include #include @@ -107,8 +108,22 @@ long arch_do_sysctl(struct xen_sysctl *sysctl, ret = -EFAULT; } break; + case DOM0_SHADOW_CONTROL: + { + struct domain *d; + ret = -ESRCH; + d = find_domain_by_id(op->u.shadow_control.domain); + if ( d != NULL ) + { + ret = shadow_control_op(d, &op->u.shadow_control, u_dom0_op); + put_domain(d); + copy_to_guest(u_dom0_op, op, 1); + } + } + break; default: + printk("%s: unsupported op: 0x%x\n", __func__, (op->cmd)); ret = -ENOSYS; break; } diff --git a/xen/include/asm-powerpc/shadow.h b/xen/include/asm-powerpc/shadow.h index d5eb849302..11c349c1d5 100644 --- a/xen/include/asm-powerpc/shadow.h +++ b/xen/include/asm-powerpc/shadow.h @@ -56,4 +56,8 @@ static inline void mark_dirty(struct domain *d, unsigned int mfn) return; } #define gnttab_mark_dirty(d, f) mark_dirty((d), (f)) + +extern int shadow_control_op(struct domain *d, + dom0_shadow_control_t *sc, + XEN_GUEST_HANDLE(dom0_op_t) u_dom0_op); #endif -- 2.30.2